gh-140067: Fix memory leak in sub-interpreter creation #140111
Merged
Merged
Conversation
…e-140067.ID2gOm.rst Co-authored-by: Kumar Aditya <kumaraditya@python.org>
Co-authored-by: Kumar Aditya <kumaraditya@python.org>
Co-authored-by: Kumar Aditya <kumaraditya@python.org>
Contributor
|
On main without fix: With fix: |
kumaraditya303
approved these changes
Oct 14, 2025
ZeroIntensity
approved these changes
Oct 14, 2025
|
GH-140118 is a backport of this pull request to the 3.14 branch. |
|
GH-140118 is a backport of this pull request to the 3.14 branch. |
kumaraditya303
added a commit
to kumaraditya303/cpython
that referenced
this pull request
Oct 14, 2025
…ythonGH-140111) Fix memory leak in sub-interpreter creation caused by overwriting of the previously used `_malloced` field. Now the pointer is stored in the first word of the memory block to avoid it being overwritten accidentally. (cherry picked from commit 59547a2) Co-authored-by: Shamil <ashm.tech@proton.me> Co-authored-by: Kumar Aditya <kumaraditya@python.org>
ZeroIntensity
added a commit
to ZeroIntensity/cpython
that referenced
this pull request
Oct 14, 2025
…ython#140111)" This reverts commit 59547a2.
Member
kumaraditya303
pushed a commit
that referenced
this pull request
Oct 15, 2025
kumaraditya303
added a commit
to kumaraditya303/cpython
that referenced
this pull request
Oct 17, 2025
…140111) Fix memory leak in sub-interpreter creation caused by overwriting of the previously used `_malloced` field. Now the pointer is stored in the first word of the memory block to avoid it being overwritten accidentally. Co-authored-by: Kumar Aditya <kumaraditya@python.org>
kumaraditya303
added a commit
that referenced
this pull request
Oct 18, 2025
…0261) Fix memory leak in sub-interpreter creation caused by overwriting of the previously used `_malloced` field. Now the pointer is stored in the first word of the memory block to avoid it being overwritten accidentally. Co-authored-by: Kumar Aditya <kumaraditya@python.org>
kumaraditya303
added a commit
that referenced
this pull request
Oct 18, 2025
) (#140118) * [3.14] gh-140067: Fix memory leak in sub-interpreter creation (GH-140111) Fix memory leak in sub-interpreter creation caused by overwriting of the previously used `_malloced` field. Now the pointer is stored in the first word of the memory block to avoid it being overwritten accidentally. (cherry picked from commit 59547a2) Co-authored-by: Shamil <ashm.tech@proton.me> Co-authored-by: Kumar Aditya <kumaraditya@python.org>
StanFromIreland
pushed a commit
to StanFromIreland/cpython
that referenced
this pull request
Dec 6, 2025
…140111) Fix memory leak in sub-interpreter creation caused by overwriting of the previously used `_malloced` field. Now the pointer is stored in the first word of the memory block to avoid it being overwritten accidentally. Co-authored-by: Kumar Aditya <kumaraditya@python.org>
StanFromIreland
pushed a commit
to StanFromIreland/cpython
that referenced
this pull request
Dec 6, 2025
…ython#140111)" (python#140140) This reverts commit 59547a2.
StanFromIreland
pushed a commit
to StanFromIreland/cpython
that referenced
this pull request
Dec 6, 2025
…140111) (python#140261) Fix memory leak in sub-interpreter creation caused by overwriting of the previously used `_malloced` field. Now the pointer is stored in the first word of the memory block to avoid it being overwritten accidentally. Co-authored-by: Kumar Aditya <kumaraditya@python.org>
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This patch fixes a memory leak detected by AddressSanitizer during subinterpreter creation.
The original allocation pointer is now stored before the aligned memory block, removing
the need for the _malloced field in PyInterpreterState.
Thanks to @kumaraditya303 for highlighting the pointer overwrite issue.
Fixes #140067